Improve GContentType usage
authorTingPing <tingping@tingping.se>
Thu, 9 Mar 2017 03:52:58 +0000 (22:52 -0500)
committerMatthias Clasen <mclasen@redhat.com>
Thu, 9 Mar 2017 04:08:56 +0000 (23:08 -0500)
Convert to content type where needed.
Should fix various issues on Windows and OS X.

https://bugzilla.gnome.org/show_bug.cgi?id=734946

gtk/gtkfilefilter.c
gtk/gtkrecentfilter.c
gtk/gtkrecentmanager.c
gtk/inspector/resource-list.c

index c843cc382806729c22bc97e30a1243ca8eba7b6f..e86f2d830413bc0ba782f74cb9d127c9a168f398 100644 (file)
@@ -669,13 +669,24 @@ gtk_file_filter_filter (GtkFileFilter           *filter,
 
       if ((filter_info->contains & rule->needed) != rule->needed)
        continue;
-      
+
       switch (rule->type)
        {
        case FILTER_RULE_MIME_TYPE:
-         if (filter_info->mime_type != NULL &&
-              g_content_type_is_a (filter_info->mime_type, rule->u.mime_type))
-           return TRUE;
+      if (filter_info->mime_type != NULL)
+        {
+          gchar *filter_content_type, *rule_content_type;
+          gboolean match;
+
+          filter_content_type = g_content_type_from_mime_type (filter_info->mime_type);
+          rule_content_type = g_content_type_from_mime_type (rule->u.mime_type);
+          match = g_content_type_is_a (filter_content_type, rule_content_type);
+          g_free (filter_content_type);
+          g_free (rule_content_type);
+
+          if (match)
+            return TRUE;
+        }
          break;
        case FILTER_RULE_PATTERN:
          if (filter_info->display_name != NULL &&
index bf32dbfacfb64d33cce77d738716e99f476f3193..4062db59d9576138e073c2583a39d297f1cc6602 100644 (file)
@@ -743,9 +743,20 @@ gtk_recent_filter_filter (GtkRecentFilter           *filter,
       switch (rule->type)
         {
         case FILTER_RULE_MIME_TYPE:
-          if (filter_info->mime_type != NULL &&
-              g_content_type_is_a (filter_info->mime_type, rule->u.mime_type))
-            return TRUE;
+          if (filter_info->mime_type != NULL)
+            {
+              gchar *filter_content_type, *rule_content_type;
+              gboolean match;
+
+              filter_content_type = g_content_type_from_mime_type (filter_info->mime_type);
+              rule_content_type = g_content_type_from_mime_type (rule->u.mime_type);
+              match = g_content_type_is_a (filter_content_type, rule_content_type);
+              g_free (filter_content_type);
+              g_free (rule_content_type);
+
+              if (match)
+                return TRUE;
+            }
           break;
         case FILTER_RULE_APPLICATION:
           if (filter_info->applications)
index f2dd510c5d69e52205678f1740d85f509fa5789f..64c60803060502e86b95a4a3e28a46f341480916 100644 (file)
@@ -775,7 +775,7 @@ gtk_recent_manager_add_item_query_info (GObject      *source_object,
   GtkRecentManager *manager = user_data;
   GtkRecentData recent_data;
   GFileInfo *file_info;
-  gchar *uri, *basename;
+  gchar *uri, *basename, *content_type;
 
   uri = g_file_get_uri (file);
 
@@ -801,8 +801,10 @@ gtk_recent_manager_add_item_query_info (GObject      *source_object,
   else
     {
       basename = g_file_get_basename (file);
-      recent_data.mime_type = g_content_type_guess (basename, NULL, 0, NULL);
+      content_type = g_content_type_guess (basename, NULL, 0, NULL);
+      recent_data.mime_type = g_content_type_get_mime_type (content_type);
       g_free (basename);
+      g_free (content_type);
     }
 
   recent_data.app_name = g_strdup (g_get_application_name ());
index 16e96514af6963f375f802281df89058a3799538..92082516ed179d7a23e8fccd9bd2901ed303c07b 100644 (file)
@@ -187,6 +187,11 @@ populate_details (GtkInspectorResourceList *rl,
   else
     {
       gchar *text;
+      gchar *content_image;
+      gchar *content_text;
+
+      content_image = g_content_type_from_mime_type ("image/*");
+      content_text = g_content_type_from_mime_type ("text/*");
 
       data = g_bytes_get_data (bytes, &size);
       type = g_content_type_guess (name, data, size, NULL);
@@ -199,12 +204,12 @@ populate_details (GtkInspectorResourceList *rl,
       gtk_label_set_text (GTK_LABEL (rl->priv->size_label), text);
       g_free (text);
 
-      if (g_content_type_is_a (type, "text/*"))
+      if (g_content_type_is_a (type, content_text))
         {
           gtk_text_buffer_set_text (rl->priv->buffer, data, -1);
           gtk_stack_set_visible_child_name (GTK_STACK (rl->priv->content), "text");
         }
-      else if (g_content_type_is_a (type, "image/*"))
+      else if (g_content_type_is_a (type, content_image))
         {
           gtk_image_set_from_resource (GTK_IMAGE (rl->priv->image), path);
           gtk_stack_set_visible_child_name (GTK_STACK (rl->priv->content), "image");
@@ -217,6 +222,9 @@ populate_details (GtkInspectorResourceList *rl,
 
       g_free (type);
       g_bytes_unref (bytes);
+
+      g_free (content_image);
+      g_free (content_text);
     }
 
   g_free (path);